#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>

#define QUEUEDATATTPE int

typedef struct Queuenode
{
	QUEUEDATATTPE val;
	struct Quenenode* next;
}Qnode;


typedef struct Queue
{
	Qnode* head;
	Qnode* tail;
	size_t size;
}Q;


void QInit(Q* p);
void Qpop(Q*p);
void Qpush(Q* p, QUEUEDATATTPE x);
bool QEmpty(Q* p);
QUEUEDATATTPE QBack(Q* p);
QUEUEDATATTPE QFront(Q* p);
size_t QSize(Q* p);
void QDestory(Q* p);

